| Thema |
|---|
| FEM |
| Niveau |
| fortgeschrittener Anfänger |
| Bearbeitungszeit |
| 1 Stunde |
| Autoren |
| M42kus |
| FreeCAD-Version |
| 0.17 |
| Beispieldateien |
| Siehe auch |
| None |
Der Arbeitsbereich FEM unterstützt schon viele unterschiedliche Randbedingungen und mehrere Berechnungsprogramme (Löser). Trotzdem brauchen Anwender oft Randbedingungen, die noch nicht von FreeCAD unterstützt werden. Diese Seite ist Startpunkt für eine Reihe von Anleitungen und anderen Quellen, die beschreiben, wie der Arbeitsbereich FEM mit dem vorhandenen Framework (<-?) erweitert werden kann. Während diese Reihe auch für Software-Entwickler hilfreich sein kann, ist die Idee dahinter, dass FEM-Anwender mit etwas Interesse für Python-Programmierung ermöglicht wird, selbst hinzuzufügen, was sie brauchen.
Neue Beschränkungen, Gleichungen oder Löser hinzuzufügen ist hauptsächlich Routinearbeit. Aber beim ersten Mal ist es wahrscheinlich nicht so einfach, wie es aussieht. Ein Verständnis für die folgenden Themen wird hilfreich sein:
Das Build-System muss unabhängig davon geändert werden, welche Objekte zum Arbeitsbereich FEM hinzugefügt werden sollen. Jedes Python-Modul (Datei) muss registriert werden. Der Arbeitsbereich FEM erfordert, dass jedes neue Python-Modul in Mod/Fem/CMakeLists.txt registriert wird. Dies gilt unabhängig vom Typ des Python-Moduls (GUI oder Nicht-GUI). Wo genau das Modul eingefügt werden muss, hängt von der Rolle des Moduls ab. Löser, Gleichungen und Beschränkungen verwenden alle unterschiedliche Listen. Meistens funktioniert es, nach ähnlichen Dateien zu suchen und die neue Datei in dieselbe Liste einzufügen.
Als Beispiel fügen wir eine neue Einschränkung namens pressure hinzu, die mit der Strömungsgleichung zusammenhängt. Daher wird FlowPressure häufig als Name für diese Beschränkung verwendet. Eine neue Beschränkung erfordert mindestens die folgenden neuen Module:
constraint_<name>.pyview_constraint_<name>.pyCommandFemConstraint<name>.py (kann unnötig sein)Diese drei Dateien müssen zu Mod/Fem/CMakeLists.txt hinzugefügt werden, genauso wie Mod/Fem/App/CMakeLists.txt. Alle eingefügten Codezeilen werden durch einen Startbefehl gekennzeichnet. +.
Mod/Fem/CMakeLists.txt
SET(FemObjects_SRCS
femobjects/__init__.py
femobjects/base_fempythonobject.py
femobjects/constraint_bodyheatsource.py
femobjects/constraint_electrostaticpotential.py
femobjects/constraint_flowvelocity.py
femobjects/constraint_initialflowvelocity.py
+ femobjects/constraint_initialflowpressure.py
femobjects/constraint_selfweight.py
...
femobjects/solver_ccxtools.py
)
...
SET(FemGuiViewProvider_SRCS
femviewprovider/__init__.py
femviewprovider/view_base_femconstraint.py
femviewprovider/view_base_femobject.py
femviewprovider/view_constraint_bodyheatsource.py
femviewprovider/view_constraint_electrostaticpotential.py
femviewprovider/view_constraint_flowvelocity.py
+ femviewprovider/view_constraint_flowpressure.py
femviewprovider/view_constraint_initialflowvelocity.py
femviewprovider/view_constraint_selfweight.py
...
femviewprovider/view_solver_ccxtools.py
)
Zur Organisation des Python-Codes verwendet das FEM-Modul den folgenden Ansatz. Das Modul ist in die folgenden Pakete unterteilt:
femobjects, das alle nicht-GUI-ähnlichen Python-Proxys für Dokumentobjekte enthält, undfemviewproviders, das alles GUI-bezogene wie Python-Proxys für View-Provider enthältGui' gespeichert,Gui/Resources/icons/',Gui/Resources/ui/' gespeichert.Ein Paket folgt diesem Muster nicht: femsolver. Es befindet sich auf derselben Ebene wie femobjects und femguiobjects (src/Mod/Fem/femsolver). Das Paket enthält Löser- und Gleichungs-bezogene Pakete und Module und ist wie folgt organisiert:
.femsolver .femsolver.elmer .femsolver.elmer.equations .femsolver.calculix .femsolver.calculix.equations .femsolver.z88 .femsolver.z88.equations
In FreeCAD kann ein Löser in zwei Teile unterteilt werden:
Die meisten Dateien, die sich auf einen Löser beziehen, befinden sich in einem Unterpaket des Pakets femsolver (z. B. für Elmer in femsolver/elmer). Die folgende Liste enthält alle Dateien, die mit der Implementierung eines Lösers zusammenhängen. Dies sind die Dateien, die kopiert und geändert werden müssen, um FreeCAD um einen neuen Löser zu erweitern. Das angegebene Beispiel stammt aus der Löser-Implementierung von Elmer.
Eine Gleichung repräsentiert eine bestimmte physikalische Größe, die bei der Lösung der Analyse berücksichtigt werden muss (z. B. Strömung, Wärme). Nicht alle Löser in FreeCAD unterstützen (alle) Gleichungen. Gleichungen werden durch untergeordnete Objekte des entsprechenden Löser-Objekts dargestellt. In der Baumansicht sieht dies wie folgt aus:
Die meisten löserspezifischen Optionen (z. B. maximale Iterationen, Lösungsmethode usw.) werden über die Gleichungsobjekte festgelegt. Eine Folge davon ist, dass jeder Löser seine eigene Implementierung derselben Gleichung haben muss. CalculiX hätte ein anderes Wärmeobjekt als Elmer. Um zu vermeiden, dass in der GUI mehrere Schaltflächen für dieselbe Physik vorhanden sind, fügt jedes Löserobjekt seine Gleichungen selbst hinzu.
Die eigentliche Implementierung kann in einen generischen und einen löserspezifischen Teil unterteilt werden. Der generische Teil befindet sich im Modul femsolver.equationbase. Der löserspezifische Teil befindet sich in einzelnen Equations-Unterpaketen der Löserpakete (z. B. femsolver/elmer/equations).
Das Hinzufügen neuer Gleichungen zu Elmer sollte sehr einfach sein. Für Neulinge gibt es ein Tutorial, das zeigt, wie man eine neue Gleichung zu Elmer hinzufügt, indem man den vorhandenen Elastizitätslöser zu FreeCAD hinzufügt: Tutorial FEM Gleichung hinzufügen.
Beschränkungen definieren Randbedingungen für das zu lösende Problem. In FreeCAD sind Beschränkungen nicht spezifisch für einen bestimmten Löser. Eine Problemkonfiguration kann von allen Lösern gelöst werden, die alle Bedingungen in der Analyse unterstützen.
Das Hinzufügen neuer Einschränkungen ist recht einfach. Für Neulinge gibt es ein Tutorium.: Tutorium FEM-Beschränkung hinzufügen.